home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Personal Computer World 2009 February
/
PCWFEB09.iso
/
Software
/
Linux
/
Kubuntu 8.10
/
kubuntu-8.10-desktop-i386.iso
/
casper
/
filesystem.squashfs
/
usr
/
sbin
/
syslogd-listfiles
< prev
next >
Wrap
Text File
|
2008-08-29
|
4KB
|
147 lines
#! /usr/bin/perl
# Copyright (c) 1998,9,2001,3 by Martin Schulze <joey@infodrom.org>
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
$conf = "/etc/syslog.conf";
$opt_daily = 1;
$opt_all = 0;
$opt_auth = 0;
$opt_ign_size = 0;
$opt_news = 0;
$opt_skip = '';
$opt_large = 1024*1024;
sub usage
{
print STDERR
"
Debian GNU/Linux syslogd-listfiles. Copyright (c) 1997,2001
Martin Schulze. This is free software; see the GNU General Public Licence
version 2 or later for copying conditions. There is NO warranty.
Usage: syslogd-listfiles <options>
Options: -f file specifies another syslog.conf file
-a | --all list all files (including news)
--auth list all files containing auth.<some prio>
--ignore-size don't rotate files which got too large
--large nnn define what is large in bytes (default: 1MB)
--news include news logfiles, too
-w | --weekly use weekly pattern instead of daily
-s pattern skip files matching pattern
";
}
# Test if the file was already rotated within the last n hours
# with n=5
#
sub rotated
{
my $file = shift;
my $nfile;
my $delta = 5 * 60 * 60;
my $now = time();
# /var/log/file -> /var/log/file.0
$nfile = $file . ".0";
if (-r $nfile) {
if (($now - (stat $nfile)[9]) > $delta) {
return 0;
} else {
return 1;
}
}
# /var/log/file -> /var/log/OLD/file.0
$nfile =~ s,(.*)/([^/]+),$1/OLD/$2,;
if (-r $nfile) {
if (($now - (stat $nfile)[9]) > $delta) {
return 0;
} else {
return 1;
}
}
return 0;
}
while (@ARGV) {
$_=shift(@ARGV);
if (m/^-f$/) {
$conf = shift(@ARGV);
} elsif (m/^-s$/) {
$opt_skip = shift(@ARGV);
} elsif (m/^--large$/) {
$opt_large = shift(@ARGV);
} elsif (m/^(--weekly|-w)$/) {
$opt_daily = 0;
} elsif (m/^(-a|--all)$/) {
$opt_all = 1;
} elsif (m/^--auth$/) {
$opt_auth = 1;
} elsif (m/^--ignore-size/) {
$opt_ign_size = 1;
} elsif (m/^--news$/) {
$opt_news = 1;
} else {
&usage();exit (0);
}
}
open (C, $conf) || die "Can't open $conf, $!";
while (<C>) {
next if (/^(\#|$)/);
chomp;
s/\s*(\S.*)$/$1/ if ($line);
$line .= $_;
chop ($line) if (/\\$/);
if (!/\\$/) {
$line =~ s/\s+/\t/;
$line =~ s/\t-/\t/;
push (@lines, $line) if ($line =~ /\t\/(?!dev\/)/);
$line = "";
}
}
close (C);
foreach $line (@lines) {
($pat,$file) = split (/\t/,$line);
# These files are handled by news.daily from INN, so we ignore them
next if (!$opt_news && ($pat =~ /news\.(\*|crit|err|info|notice)/));
if ($opt_all) {
$output{$file} = 1;
} elsif ($opt_auth) {
$output{$file} = 1 if ($pat =~ /auth[^\.]*\.(?!none).*/);
} else {
$everything = ($pat =~ /\*\.\*/);
$output{$file} = 1 if (($everything && $opt_daily)
|| (!$everything && !$opt_daily && !rotated ($file))
|| (!$opt_ign_size && ((stat $file)[7] >= $opt_large) && $opt_daily)
);
}
}
foreach $file (keys (%output)) {
$skip = $file;
if (!length($opt_skip) || $skip !~ /$opt_skip/) {
printf "%s\n", $file;
}
}